Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

fix: staking payouts claimed with new logic & statuses #1457

Open
wants to merge 2 commits into
base: anp-v14-claimed
Choose a base branch
from

Conversation

Imod7
Copy link
Contributor

@Imod7 Imod7 commented Jun 24, 2024

Description

This PR is intended to be merged in this one #1436 and its changes are aligned with the staking-info updates from this PR #1445

Changes

 

  • Renamed fetchCommissionAndLedger to fetchCommissionLedgerAndClaimed because it now also returns claimedRewards.
  • The logic for claimedRewards is based on this PR for the staking-info endpoint.
  • The claimed field returned from staking-payouts is no longer a boolean value; It now has different statuses.
  • A status called undefined was added which means that with the current information, we cannot determine if the rewards of the era were claimed, unclaimed or partially claimed.
    • an example is the case when the only available info is lastReward and it is null, then claimed is set to undefined
  • With the old code, if none of the checks/properties/calls could define the claimedfield, we would continue/skip that era and do not return any info about that era. Now we don't, we just set the claimed field as undefined.
  • Some of the logic was moved from function deriveEraPayouts to fetchCommissionAndLedger.
  • The case era < 518 && chain is Kusama is still working as expected. The era in this case is "automatically" considered as claimed.

Testing

  • Tested cases claimed and unclaimed
  • Tested for era < 518 in Kusama chain
  • Tested a case where lastReward is available and it is null
  • Updated the existing tests
  • I did not test a case with a partially claimed era

### Todos

  • Minor adjustment for query param unclaimedOnly to work with the new statuses.

@Imod7 Imod7 requested a review from a team as a code owner June 24, 2024 18:24
@Imod7 Imod7 changed the title fix staking payouts claimed with new logic & statuses fix: staking payouts claimed with new logic & statuses Jun 24, 2024
unclaimed = 'unclaimed',
undefined = 'undefined',
}

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I think this needs to be updated in the docs as well!

export interface IPayout {
validatorId: string;
nominatorStakingPayout: string;
claimed: boolean;
claimed: IStatus;
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I think this needs to be updated in the docs as well! as before

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

2 participants